博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
正则表达式—贪婪与非贪婪模式
阅读量:7069 次
发布时间:2019-06-28

本文共 930 字,大约阅读时间需要 3 分钟。

hot3.png

今天在进行一个网页数据的抓取过程中遇到了一点点的问题,要进行网页中图片的抓取,翻来覆去只能取到最后一张图片的地址,不能进行全部的匹配,后查资料得知正则中的表达式默认情况下是贪婪模式的,所以匹配到了最后一个符合条件的表达式,下面贴出小例子,只是便于大家理解

51 $str = ''; 52 preg_match_all("//is", $str, $outstr); 53 print_r($outstr[1]);

这种情况匹配结果为:
Array(    [0] => a.jpg">

也就是匹配到了最后的一个图片地址,因为正则表达式在默认情况下是贪婪的,所以匹配到了最后一个图片地址。
preg_match_all("//is", $str, $outstr);

将代码改为上面的形式,则可以匹配出想要的结果,

Array ( [0] => a.jpg [1] => b.jpg [2] => v.jpg )

? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个 "o",而 'o+' 将匹配所有 'o'。

当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。考虑这个表达式:a.*b,它将会匹配最长的以 a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。

有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:

a.*?b匹配最短的,以a开始,以b 结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)ab(第四到第五个字符)

转载于:https://my.oschina.net/yueguanqun/blog/66247

你可能感兴趣的文章
(5)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- 熔断降级(Polly)
查看>>
“六面魔方”里的浪潮
查看>>
聚焦理论—《可以量化的管理学》
查看>>
如何给网站配置SSL证书(https)
查看>>
学习导航
查看>>
独家 | 如何改善你的训练数据集?(附案例)
查看>>
Linux学习(十):查看文件系统(dumpe2fs)
查看>>
用SQL命令查看Mysql数据库大小
查看>>
阿里云MaxCompute技术共享计划 首波技术公开课干货集锦
查看>>
系统思考负反馈之西蒙的组织均衡分析
查看>>
C# winform嵌入unity3D
查看>>
Ubuntu 16.04安装RabbitVCS替代TortoiseSVN/TortoiseGit
查看>>
Linux下的/etc/crontab文件和crontab -e命令区别及Crontab命令详解(转)
查看>>
软银展示5G应用,用超高速通信技术控制机器人实时“守门”
查看>>
OpenJDK与JDK的区别分析
查看>>
我的大学四年
查看>>
OpenID Connect 协议入门指南
查看>>
MySql基本数据类型(转)
查看>>
Atom飞行手册翻译: 4.4 Atom中的序列化
查看>>
AMD楚含进:为什么说VR正在颠覆传统的电竞?
查看>>